package org.dromara.datacheck.service.jst;

import org.dromara.common.mybatis.core.page.PageQuery;
import org.dromara.common.mybatis.core.page.TableDataInfo;
import org.dromara.datacheck.domain.bo.JstAndJDTableDataEntryBo;
import org.dromara.datacheck.domain.bo.jst.JstPurchaseEnterWarehouseOrderBo;
import org.dromara.datacheck.domain.jst.JstPurchaseEnterWarehouseOrder;
import org.dromara.datacheck.domain.vo.jst.JstPurchaseEnterWarehouseOrderVo;

import java.util.Collection;
import java.util.List;

/**
 * 聚水潭-采购入库单Service接口
 *
 * @author 刘武贵
 * @date 2024-09-08
 */
public interface IJstPurchaseEnterWarehouseOrderService {

    /**
     * 查询聚水潭-采购入库单
     *
     * @param id 主键
     * @return 聚水潭-采购入库单
     */
    JstPurchaseEnterWarehouseOrderVo queryById(Long id);

    /**
     * 分页查询聚水潭-采购入库单列表
     *
     * @param bo        查询条件
     * @param pageQuery 分页参数
     * @return 聚水潭-采购入库单分页列表
     */
    TableDataInfo<JstPurchaseEnterWarehouseOrderVo> queryPageList(JstPurchaseEnterWarehouseOrderBo bo, PageQuery pageQuery);

    /**
     * 查询符合条件的聚水潭-采购入库单列表
     *
     * @param bo 查询条件
     * @return 聚水潭-采购入库单列表
     */
    List<JstPurchaseEnterWarehouseOrderVo> queryList(JstPurchaseEnterWarehouseOrderBo bo);

    /**
     * 新增聚水潭-采购入库单
     *
     * @param bo 聚水潭-采购入库单
     * @return 是否新增成功
     */
    Boolean insertByBo(JstPurchaseEnterWarehouseOrderBo bo);

    /**
     * 修改聚水潭-采购入库单
     *
     * @param bo 聚水潭-采购入库单
     * @return 是否修改成功
     */
    Boolean updateByBo(JstPurchaseEnterWarehouseOrderBo bo);

    /**
     * 校验并批量删除聚水潭-采购入库单信息
     *
     * @param ids     待删除的主键集合
     * @param isValid 是否进行有效性校验
     * @return 是否删除成功
     */
    Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);

    /**
     * 查询聚水潭-采购入库单列表所有数据
     *
     * @return 聚水潭-采购入库单列表
     */
    List<JstPurchaseEnterWarehouseOrder> queryAll();

    /**
     * 清空聚水潭-采购入库单列表所有数据
     *
     * @return 聚水潭-采购入库单列表
     */
    Integer deleteAll();

    /**
     * 分页查询聚水潭-采购入库单列表
     * 业务查询条件：根据operator_warehouse_owner名称为国内工厂在途仓和深圳/东莞仓查询
     *
     * @param bo        查询条件
     * @param pageQuery 分页参数
     * @return 聚水潭-采购入库单分页列表
     */
    TableDataInfo<JstPurchaseEnterWarehouseOrderVo> queryPageListByDongGuanAndGuoNei(JstPurchaseEnterWarehouseOrderBo bo, PageQuery pageQuery);

    /**
     * 查询聚水潭-采购入库单列表以及金蝶-采购入库单数据汇总（按日期汇总）
     */
    TableDataInfo<JstAndJDTableDataEntryBo> jstAndJdSumByDate();

    /**
     * 查询聚水潭-采购入库单列表（金蝶缺少的数据）
     * 业务查询条件：根据operator_warehouse_owner操作仓储方名称为国内工厂在途仓和深圳/东莞仓查询
     * 场景分类：1、采购流程（含委外）-东莞仓，国内在途仓
     */
    TableDataInfo<JstPurchaseEnterWarehouseOrderVo> listByDongGuanAndGuoNeiByJdDeficiency1(JstPurchaseEnterWarehouseOrderBo bo, PageQuery pageQuery);

    /**
     * 导出聚水潭-采购入库单列表（金蝶缺少的数据）
     */
    List<JstPurchaseEnterWarehouseOrderVo> queryListByDongguanAndGuoneiByJdDeficiency(JstPurchaseEnterWarehouseOrderBo bo);
}
